[POWERPC][XEN] Clean up init_frame_table()
authorJimi Xenidis <jimix@watson.ibm.com>
Thu, 14 Sep 2006 18:20:48 +0000 (14:20 -0400)
committerJimi Xenidis <jimix@watson.ibm.com>
Thu, 14 Sep 2006 18:20:48 +0000 (14:20 -0400)
figure out its size correctly and remove unused global

Signed-off-by: Jimi Xenidis <jimix@watson.ibm.com>
Signed-off-by: Hollis Blanchard <hollisb@us.ibm.com>
xen/arch/powerpc/mm.c
xen/include/asm-powerpc/mm.h

index 1f119f4a7598e652866e1dbaba7d456fa65c38c8..530a64fb47ff0b85b85386fc645398c4784f0d47 100644 (file)
@@ -39,7 +39,6 @@
 
 /* Frame table and its size in pages. */
 struct page_info *frame_table;
-unsigned long frame_table_size;
 unsigned long max_page;
 unsigned long total_pages;
 
@@ -190,17 +189,20 @@ int get_page_type(struct page_info *page, unsigned long type)
 void __init init_frametable(void)
 {
     unsigned long p;
+    unsigned long nr_pages;
+    int i;
 
-    frame_table_size = PFN_UP(max_page * sizeof(struct page_info));
+    nr_pages = PFN_UP(max_page * sizeof(struct page_info));
+    nr_pages = min(nr_pages, (4UL << (20 - PAGE_SHIFT)));
+    
 
-    p = alloc_boot_pages(min(frame_table_size, 4UL << 20), 1);
+    p = alloc_boot_pages(nr_pages, 1);
     if (p == 0)
         panic("Not enough memory for frame table\n");
 
     frame_table = (struct page_info *)(p << PAGE_SHIFT);
-    frame_table_size = (frame_table_size + PAGE_SIZE - 1) & PAGE_MASK;
-
-    memset(frame_table, 0, frame_table_size);
+    for (i = 0; i < nr_pages; i += 1)
+        clear_page((void *)((p + i) << PAGE_SHIFT));
 }
 
 long arch_memory_op(int op, XEN_GUEST_HANDLE(void) arg)
index 734c7a285636e6dd8a703b68bd937cd6d8520794..b6dc8df34eb7e1c25c8aacc97b3a25665f6a72d1 100644 (file)
@@ -229,8 +229,6 @@ extern vm_assist_info_t vm_assist_info[];
 #define share_xen_page_with_guest(p, d, r) do { } while (0)
 #define share_xen_page_with_privileged_guests(p, r) do { } while (0)
 
-extern unsigned long frame_table_size;
-
 /* hope that accesses to this will fail spectacularly */
 #define machine_to_phys_mapping ((u32 *)-1UL)